<template>
  <div>
    <SearchForm
        @search="onSearch"
        @reset="onReset"
        :search-list="searchList" :search-params="searchParams">
    </SearchForm>

    <div class="table-layout">
      <el-card shadow="never">
        <div class="table-handle">
          <el-button type="primary" size="mini" icon="el-icon-plus" @click="onAdd">新增</el-button>
        </div>
        <div class="table-box">
          <el-table
              size="large"
              stripe
              border
              v-loading="loading"
              max-height="500px"
              :data="tableData"
              row-key="id"
              element-loading-spinner="el-icon-loading"
              element-loading-background="rgba(255, 255, 255, 0.8)"
              @selection-change="onSelect"
          >
            <el-table-column prop="type" label="企业类型" width="150"/>
            <el-table-column prop="text" label="企业名称" width="250"/>
            <el-table-column prop="enterprise_type" label="企业分类" width="150">
              <template slot-scope="scope">
                {{ scope.row.enterprise_type || '-' }}
              </template>
            </el-table-column>
            <el-table-column label="操作" fixed="right" width="150">
              <template slot-scope="scope">
                <el-button type="text" @click="onEdit(scope.row)">编辑</el-button>
                <el-button type="text" style="color: #F82222" @click="onDelete(scope.row)">删除</el-button>
              </template>
            </el-table-column>
          </el-table>
        </div>
      </el-card>
      <div class="page-box">
        <el-pagination
            background
            :current-page="pageNo"
            :page-sizes="pageSizes"
            :page-size="pageSize"
            layout="total, sizes, prev, pager, next, jumper"
            :total="totalSize"
            @size-change="changePageSize"
            @current-change="changePageNo"
        />
      </div>
    </div>
    <Add ref="addFormRef" @get-page="initData" />
  </div>
</template>
<script>

import crud from "@/mixins/crud";
import { http } from "@/api";
import Add from "./add";

export default {
  name: "EnterpriseIndex",
  components: {
    Add
  },
  mixins: [crud],
  data() {
    return {
      request: http.enterprise,
      searchList: [
        {
          label: '企业类型',
          prop: 'type',
          name: 'input',
          clearable: true
        },
        {
          label: '企业名称',
          prop: 'text',
          name: 'input',
          clearable: true
        },
        {
          label: '企业分类',
          prop: 'enterprise_type',
          name: 'input',
          clearable: true
        }
      ],
      searchParams: {
        type: '',
        text: '',
        enterprise_type: ''
      },
      defaultParams: {
      },
      tableData: []
    }
  },
  methods: {
    onDelete(row) {
      this.$confirm('确认删除该企业信息吗?', '提示', {
        confirmButtonText: '确定',
        cancelButtonText: '取消',
        type: 'warning'
      }).then(() => {
        this.request.delete(row.id).then(() => {
          this.$message.success('删除成功')
          this.initData()
        })
      }).catch(() => {
        this.$message.info('已取消删除')
      })
    }
  }
}
</script>

<style scoped lang="scss">
.table-layout {
  margin-top: 20px;
}
.table-handle {
  margin-bottom: 20px;
}
.page-box {
  margin-top: 20px;
  text-align: right;
}
</style>
